Securing Resources Using Unique Internet Protocol Addresses

ABSTRACT

A security service controller for multiple entities assigns a unique set of Internet Protocol (IP) addresses to each entity from among the multiple entities. The security service controller processes, for a client device authorized by a given entity, network traffic via the unique set of IP addresses for the given entity. The security service controller provides, to the client device authorized by the given entity, access to network resources associated with the given entity via the unique set of IP addresses for the given entity.

PRIORITY CLAIM

This application claims priority to U.S. Provisional Patent ApplicationNo. 63/261,850, titled “COMPUTER NETWORK SECURITY,” filed on Sep. 30,2021, the entire disclosure of which is incorporated herein byreference.

TECHNICAL FIELD

Embodiments pertain to computer architecture. Some embodiments relate tocomputer network security. Some embodiments relate to protecting asubset of computing resources from an active threat. Some embodimentsrelate to securing Internet applications using a dedicated InternetProtocol (IP) space.

BACKGROUND

Many computers are connected to the Internet. Some of these computersmay store, transmit or receive sensitive data. Techniques for computerand Internet security may be desirable.

BRIEF DESCRIPTION OF THE DRAWINGS

FIG. 1 is a block diagram of a computing machine, in accordance withsome embodiments.

FIG. 2 is a block diagram of an example system in which protecting asubset of computing resources from an active threat may be implemented,in accordance with some embodiments.

FIG. 3 is a data flow diagram of an example process for protecting asubset of computing resources from an active threat, in accordance withsome embodiments.

FIG. 4 is a flowchart of an example process associated with protecting asubset of resources at a computing machine from an active threat, inaccordance with some embodiments.

FIG. 5 is a diagram of an example system in which securing Internetapplications using a dedicated Internet Protocol space may beimplemented, in accordance with some embodiments.

FIG. 6 is a flowchart of an example process associated with securingInternet applications using a dedicated Internet Protocol space, inaccordance with some embodiments.

DETAILED DESCRIPTION

The following description and the drawings sufficiently illustratespecific embodiments to enable those skilled in the art to practicethem. Other embodiments may incorporate structural, logical, electrical,process, and other changes. Portions and features of some embodimentsmay be included in, or substituted for, those of other embodiments.Embodiments set forth in the claims encompass all available equivalentsof those claims.

Aspects of the present technology may be implemented as part of acomputer system. The computer system may be one physical machine, or maybe distributed among multiple physical machines, such as by role orfunction, or by process thread in the case of a cloud computingdistributed model. In various embodiments, aspects of the technology maybe configured to run in virtual machines that in turn are executed onone or more physical machines. It will be understood by persons of skillin the art that features of the technology may be realized by a varietyof different suitable machine implementations.

The system includes various engines, each of which is constructed,programmed, configured, or otherwise adapted, to carry out a function orset of functions. The term engine as used herein means a tangibledevice, component, or arrangement of components implemented usinghardware, such as by an application specific integrated circuit (ASIC)or field-programmable gate array (FPGA), for example, or as acombination of hardware and software, such as by a processor-basedcomputing platform and a set of program instructions that transform thecomputing platform into a special-purpose device to implement theparticular functionality. An engine may also be implemented as acombination of the two, with certain functions facilitated by hardwarealone, and other functions facilitated by a combination of hardware andsoftware.

In an example, the software may reside in executable or non-executableform on a tangible machine-readable storage medium. Software residing innon-executable form may be compiled, translated, or otherwise convertedto an executable form prior to, or during, runtime. In an example, thesoftware, when executed by the underlying hardware of the engine, causesthe hardware to perform the specified operations. Accordingly, an engineis physically constructed, or specifically configured (e.g., hardwired),or temporarily configured (e.g., programmed) to operate in a specifiedmanner or to perform part or all of any operations described herein inconnection with that engine.

Considering examples in which engines are temporarily configured, eachof the engines may be instantiated at different moments in time. Forexample, where the engines comprise a general-purpose hardware processorcore configured using software, the general-purpose hardware processorcore may be configured as respective different engines at differenttimes. Software may accordingly configure a hardware processor core, forexample, to constitute a particular engine at one instance of time andto constitute a different engine at a different instance of time.

In certain implementations, at least a portion, and in some cases, all,of an engine may be executed on the processor(s) of one or morecomputers that execute an operating system, system programs, andapplication programs, while also implementing the engine usingmultitasking, multithreading, distributed (e.g., cluster, peer-peer,cloud, etc.) processing where appropriate, or other such techniques.Accordingly, each engine may be realized in a variety of suitableconfigurations, and should generally not be limited to any particularimplementation exemplified herein, unless such limitations are expresslycalled out.

In addition, an engine may itself be composed of more than onesub-engines, each of which may be regarded as an engine in its ownright. Moreover, in the embodiments described herein, each of thevarious engines corresponds to a defined functionality; however, itshould be understood that in other contemplated embodiments, eachfunctionality may be distributed to more than one engine. Likewise, inother contemplated embodiments, multiple defined functionalities may beimplemented by a single engine that performs those multiple functions,possibly alongside other functions, or distributed differently among aset of engines than specifically illustrated in the examples herein.

As used herein, the term “model” encompasses its plain and ordinarymeaning. A model may include, among other things, one or more engineswhich receive an input and compute an output based on the input. Theoutput may be a classification. For example, an image file may beclassified as depicting a cat or not depicting a cat. Alternatively, theimage file may be assigned a numeric score indicating a likelihoodwhether the image file depicts the cat, and image files with a scoreexceeding a threshold (e.g., 0.9 or 0.95) may be determined to depictthe cat.

This document may reference a specific number of things (e.g., “sixmobile devices”). Unless explicitly set forth otherwise, the numbersprovided are examples only and may be replaced with any positiveinteger, integer or real number, as would make sense for a givensituation. For example, “six mobile devices” may, in alternativeembodiments, include any positive integer number of mobile devices.Unless otherwise mentioned, an object referred to in singular form(e.g., “a computer” or “the computer”) may include one or multipleobjects (e.g., “the computer” may refer to one or multiple computers).

FIG. 1 illustrates a circuit block diagram of a computing machine 100 inaccordance with some embodiments. In some embodiments, components of thecomputing machine 100 may store or be integrated into other componentsshown in the circuit block diagram of FIG. 1 . For example, portions ofthe computing machine 100 may reside in the processor 102 and may bereferred to as “processing circuitry.” Processing circuitry may includeprocessing hardware, for example, one or more central processing units(CPUs), one or more graphics processing units (GPUs), and the like. Inalternative embodiments, the computing machine 100 may operate as astandalone device or may be connected (e.g., networked) to othercomputers. In a networked deployment, the computing machine 100 mayoperate in the capacity of a server, a client, or both in server-clientnetwork environments. In an example, the computing machine 100 may actas a peer machine in peer-to-peer (P2P) (or other distributed) networkenvironment. In this document, the phrases P2P, device-to-device (D2D)and sidelink may be used interchangeably. The computing machine 100 maybe a specialized computer, a personal computer (PC), a tablet PC, apersonal digital assistant (PDA), a mobile telephone, a smart phone, aweb appliance, a network router, switch or bridge, or any machinecapable of executing instructions (sequential or otherwise) that specifyactions to be taken by that machine.

Examples, as described herein, may include, or may operate on, logic ora number of components, modules, or mechanisms. Modules and componentsare tangible entities (e.g., hardware) capable of performing specifiedoperations and may be configured or arranged in a certain manner. In anexample, circuits may be arranged (e.g., internally or with respect toexternal entities such as other circuits) in a specified manner as amodule. In an example, the whole or part of one or more computersystems/apparatus (e.g., a standalone, client or server computer system)or one or more hardware processors may be configured by firmware orsoftware (e.g., instructions, an application portion, or an application)as a module that operates to perform specified operations. In anexample, the software may reside on a machine readable medium. In anexample, the software, when executed by the underlying hardware of themodule, causes the hardware to perform the specified operations.

Accordingly, the term “module” (and “component”) is understood toencompass a tangible entity, be that an entity that is physicallyconstructed, specifically configured (e.g., hardwired), or temporarily(e.g., transitorily) configured (e.g., programmed) to operate in aspecified manner or to perform part or all of any operation describedherein. Considering examples in which modules are temporarilyconfigured, each of the modules need not be instantiated at any onemoment in time. For example, where the modules comprise ageneral-purpose hardware processor configured using software, thegeneral-purpose hardware processor may be configured as respectivedifferent modules at different times. Software may accordingly configurea hardware processor, for example, to constitute a particular module atone instance of time and to constitute a different module at a differentinstance of time.

The computing machine 100 may include a hardware processor 102 (e.g., acentral processing unit (CPU), a GPU, a hardware processor core, or anycombination thereof), a main memory 104 and a static memory 106, some orall of which may communicate with each other via an interlink (e.g.,bus) 108. Although not shown, the main memory 104 may contain any or allof removable storage and non-removable storage, volatile memory ornon-volatile memory. The computing machine 100 may further include avideo display unit 110 (or other display unit), an alphanumeric inputdevice 112 (e.g., a keyboard), and a user interface (UI) navigationdevice 114 (e.g., a mouse). In an example, the display unit 110, inputdevice 112 and UI navigation device 114 may be a touch screen display.The computing machine 100 may additionally include a storage device(e.g., drive unit) 116, a signal generation device 118 (e.g., aspeaker), a network interface device 120, and one or more sensors 121,such as a global positioning system (GPS) sensor, compass,accelerometer, or other sensor. The computing machine 100 may include anoutput controller 128, such as a serial (e.g., universal serial bus(USB), parallel, or other wired or wireless (e.g., infrared (IR), nearfield communication (NFC), etc.) connection to communicate or controlone or more peripheral devices (e.g., a printer, card reader, etc.).

The drive unit 116 (e.g., a storage device) may include a machinereadable medium 122 on which is stored one or more sets of datastructures or instructions 124 (e.g., software) embodying or utilized byany one or more of the techniques or functions described herein. Theinstructions 124 may also reside, completely or at least partially,within the main memory 104, within static memory 106, or within thehardware processor 102 during execution thereof by the computing machine100. In an example, one or any combination of the hardware processor102, the main memory 104, the static memory 106, or the storage device116 may constitute machine readable media.

While the machine readable medium 122 is illustrated as a single medium,the term “machine readable medium” may include a single medium ormultiple media (e.g., a centralized or distributed database, and/orassociated caches and servers) configured to store the one or moreinstructions 124.

The term “machine readable medium” may include any medium that iscapable of storing, encoding, or carrying instructions for execution bythe computing machine 100 and that cause the computing machine 100 toperform any one or more of the techniques of the present disclosure, orthat is capable of storing, encoding or carrying data structures used byor associated with such instructions. Non-limiting machine readablemedium examples may include solid-state memories, and optical andmagnetic media. Specific examples of machine readable media may include:non-volatile memory, such as semiconductor memory devices (e.g.,Electrically Programmable Read-Only Memory (EPROM), ElectricallyErasable Programmable Read-Only Memory (EEPROM)) and flash memorydevices; magnetic disks, such as internal hard disks and removabledisks; magneto-optical disks; Random Access Memory (RAM); and CD-ROM andDVD-ROM disks. In some examples, machine readable media may includenon-transitory machine readable media. In some examples, machinereadable media may include machine readable media that is not atransitory propagating signal.

The instructions 124 may further be transmitted or received over acommunications network 126 using a transmission medium via the networkinterface device 120 utilizing any one of a number of transfer protocols(e.g., frame relay, Internet Protocol (IP), transmission controlprotocol (TCP), user datagram protocol (UDP), hypertext transferprotocol (HTTP), etc.). Example communication networks may include alocal area network (LAN), a wide area network (WAN), a packet datanetwork (e.g., the Internet), mobile telephone networks (e.g., cellularnetworks), Plain Old Telephone (POTS) networks, and wireless datanetworks (e.g., Institute of Electrical and Electronics Engineers (IEEE)802.11 family of standards known as Wi-Fi®, IEEE 802.16 family ofstandards known as WiMax®), IEEE 802.15.4 family of standards, a LongTerm Evolution (LTE) family of standards, a Universal MobileTelecommunications System (UMTS) family of standards, peer-to-peer (P2P)networks, among others. In an example, the network interface device 120may include one or more physical jacks (e.g., Ethernet, coaxial, orphone jacks) or one or more antennas to connect to the communicationsnetwork 126.

FIG. 2 is a block diagram of an example system 200 in which protecting asubset of computing resources from an active threat may be implemented,in accordance with some embodiments.

As shown, the system 200 includes a computing machine 202. The computingmachine 202 may include all or a portion of the components of thecomputing machine 100 shown in FIG. 1 . As shown, the computing machine202 stores a security policy 204, supervised resources 206, andunsupervised resources 208. The security policy 204 stores and enforcessecurity rules which limit accessing, sharing, modifying, andtransmitting of supervised resources 206. The security rules in thesecurity policy 204 do not apply to unsupervised resources 208.

In some embodiments, the security policy 204 is associated with abusiness. The supervised resources 206 are business resources, and theunsupervised resources 208 are personal resources stored at thecomputing machine 202. The resources may include files, email messages,applications, network ports, network destinations, website accesspermissions, and external filesystem access permissions.

As used herein, the phrase “security policy” encompasses its plain andordinary meaning. A security policy defines authorized and unauthorizedactions with respect to a set of computing resources (e.g., businesscomputing resources or each and every computing resource at thecomputing machine), and prevents a computing machine (e.g., thecomputing machine 202) from taking unauthorized actions. A securitypolicy may include various access permissions (e.g., by antivirus orother software) and computing resource sharing permissions. The securitypolicy may require that certain actions (e.g., entering a password,verifying user identity by fingerprint or facial scan, and the like) betaken before accessing a computing resource covered by the securitypolicy or before sharing (e.g., via a messaging service) the computingresource covered by the security policy.

In some cases, the security policy may include a tracking policy or amonitoring policy. For example, the tracking policy or the monitoringpolicy may allow a supervisor (e.g., at a remote computing machine) tomonitor activity of the user of the computing machine (e.g., thecomputing machine 202) with respect to the computing resources coveredby the tracking policy or the monitoring policy. The tracking policy orthe monitoring policy may store records of the activity of the user ofthe computing machine with respect to the computing resources at aserver or a data repository that is accessible to the supervisor. Thetracking policy or the monitoring policy may apply to resources withinthe supervised zone, and not to computing resources outside thesupervised zone.

As shown, the computing machine 202 is connected to a network 210. Thenetwork 210 may include the Internet, an intranet, a local area network,a wide area network, a Wi-Fi® network, a cellular network, and the like.The system 200 also includes a security event detector 212. The securityevent detector 212 may be implemented in software and/or hardware andmay reside on the computing machine 202, on another machine or on thenetwork 210. The security event detector 212 may include one or more ofan antivirus program, an antimalware program, a network threat detectorand the like. The security event detector 212 detects active threat(s)(or the absence of active threat(s)) at the computing machine 202 or onthe network 210. As shown, the security event detector 212 is directlyconnected with the network 210 and the computing machine 202. Inalternative embodiments, the security event detector 212 may reside onthe computing machine 202 or may reside on the network 210. The securityevent detector 212 might not be connected to the network 210 and/or thecomputing machine 202. In some implementations, the security eventdetector 212 resides at the computing machine 202 or in a cloudresource. The cloud resources identifies active threats at the computingmachine 202 or the network 210 associated with the computing machine202.

As used herein, the phrase “active threat” may include, among otherthings, any security threat. An active threat may include one or moreof: a computer virus, unusual (e.g., different from a baseline) networkactivity, unusual remote access to the computing machine 202, and thelike. An active threat may include data-related risks (insider threats,e.g., user pulling data out of machine or other behavior) or securitythreat-related feeds (threat feeds that flag indicators that networktraffic, file(s), application(s), memory, domain(s) or user behavior area security threat). An active threat may include an external machine (orlocal malware) making unauthorized changes or receiving unauthorizedaccess to a computer, such as the computing machine 202. The changes maybe unauthorized by an administrator or by a user of the computer.

An example of the interoperation of the security event detector 212, thesecurity policy 204, the supervised resources 206, and the unsupervisedresources 208 is described in conjunction with FIG. 3 . FIG. 3 is a dataflow diagram of an example process 300 for protecting a subset ofcomputing resources from an active threat, in accordance with someembodiments.

The process 300 begins at operation 302 when, in usual operation of thecomputing machine 202, the security policy 204 allows access (e.g., to auser of the computing machine 202) to the supervised resources 206. Atblock 304, the security policy 204 allows access to the unsupervisedresources 208.

At block 306, the security event detector 212 determines that an activethreat exists. The security event detector 212 may notify the computingmachine 202 that the active threat exists. The security event detector212 may scan the computing machine 202 and/or the network 210 forthreats once every threshold time period (e.g., once per minute) and maydetermine, during this scanning, that there is an active threat. Thesecurity event detector 212 may scan the computing machine 202 upondetection of occurrence of a specified event. The specified event maybe, for example, a download to the computing machine 202, aninstallation of an application at the computing machine 202, or amodification of software at the computing machine. The specified eventmay be any event detectable by the security event detector 212 or thecomputing machine 202, such as a mouse click, a touch of a touchscreen,a keyboard press, n mouse clicks, n touches of the touch screen, nkeyboard presses, or a combination of n of the above events, where n isa positive integer. For example, the specified event may occur everytime a total number of mouse clicks, touchscreen touches, and keyboardpresses exceeds m, where m is a positive integer. In someimplementations, determining that the active threat exists includesscanning, using the security event detector 212, the computing machine202 and/or the network 210 to identify the active threat.

At block 308, in response to determining that the active threat exist,the security event detector 212 (e.g., based on rules stored in thesecurity policy 204, and/or externally to the computing machine 202)prevents (e.g., blocks) access to the supervised resources 206. Forexample, the security event detector 212 transmits, to the computingmachine 202, an instruction to block access to the supervised resources206. A user of the computing machine 202 may be notified, for example byan email message, a push notification, or another notification supportedby the operating system of the computing machine 202, that access to thesupervised resources 206 is blocked until the active threat no longerexists. At block 310, the security policy 204 continues to allow accessto the unsupervised resources 208. In preventing access to thesupervised resources 206, the security policy 204 may make one or morefiles from the supervised resources 206 inaccessible at the computingmachine 202. In preventing access to the supervised resources 206, thesecurity policy 204 may make a running application inaccessible at thecomputing machine 202. The running application is one of the supervisedresources 206 and/or accesses computing resources from among thesupervised resources 206.

At block 312, the security event detector 212 determines that an activethreat no longer exists. The security event detector 212 may notify thecomputing machine 202 that the active threat no longer exists.Alternatively, no notification is transmitted to the computing machine202. The security event detector 212 may scan the computing machine 202and/or the network 210 for threats once every threshold time period(e.g., once per minute) or upon detection of occurrence of a specifiedevent (e.g., application installation at the computing machine 202), andmay determine, during this scanning, that there is the active threat nolonger exists. In some embodiments, the security event detector 212persistently checks, once every threshold time period, (e.g., 50 secondsor 60 seconds) whether the active threat still exists at the computingmachine 202 and/or the network 210. The threshold time period may bebetween thirty and ninety seconds.

After determining that the active threat no longer exists, at block 314,the security policy 204 allows (e.g., unblocks) access to the supervisedresources 206. The security event detector 212 transmits, to thecomputing machine 202, a notification indicating that access to thesupervised resources 206 is permitted. At block 316, the security policy204 allows access to the unsupervised resources 208. After block 316,the process 300 ends.

FIG. 4 is a flowchart of an example process 400 associated withprotecting a subset of resources at a computing machine from an activethreat. In some implementations, one or more process blocks of FIG. 4may be performed by a computing machine (e.g., computing machine 100).In some implementations, one or more process blocks of FIG. 4 may beperformed by another device or a group of devices separate from orincluding the computing machine. Additionally, or alternatively, one ormore process blocks of FIG. 4 may be performed by one or more componentsof the computing machine 100, such as processor 102, main memory 104,static memory 106, network interface device 120, video display 110,alpha-numeric input device 112, UI navigation device 112, drive unit116, signal generation device 118, and output controller 128.

As shown in FIG. 4 , process 400 may include, at the computing machine,determining, by a security event detector, that an active threat existsat the computing machine, wherein the security event detector resides atthe computing machine or in a cloud resource, wherein the security eventdetector identifies active threats at the computing machine or a networkassociated with the computing machine (block 410).

As further shown in FIG. 4 , process 400 may include, at the computingmachine, preventing, in response to determining that the active threatexists, access to a subset of computing resources accessible via thecomputing machine, wherein the subset of computing resources isidentified via a security policy that applies to the subset of computingresources, wherein the security policy does not apply to one or morecomputing resources stored at the computing machine that are not in thesubset (block 420).

As further shown in FIG. 4 , process 400 may include, at the computingmachine, determining, subsequent to determining that the active threatexists, that the active threat no longer exists (block 430).

As further shown in FIG. 4 , process 400 may include, at the computingmachine, allowing, in response to determining that the active threat nolonger exists, access to the subset of computing resources (block 440).

Process 400 may include additional implementations, such as any singleimplementation or any combination of implementations described belowand/or in connection with one or more other processes describedelsewhere herein.

In a first implementation, the computing machine stores personalcomputing resources and business computing resources, wherein the subsetof computing resources comprises the business computing resources andnot the personal computing resources, wherein the computing resourcescomprise files, email messages, applications, network ports, networkdestinations, website access permissions, and external filesystem accesspermissions.

In a second implementation, determining that the active threat existscomprises scanning, using the security event detector, the computingmachine or the associated network to identify the active threat.

In a third implementation, determining that the active threat no longerexists comprises persistently checking using the security eventdetector, once every threshold time period or upon detection ofoccurrence of a specified event, whether the active threat still existsat the computing machine or the associated network.

In a fourth implementation, the threshold time period is between thirtyand ninety seconds.

In a fifth implementation, preventing access to the subset comprisesmaking a running application inaccessible at the computing machine,wherein the running application is in the subset or accesses a computingresource from the subset.

In a sixth implementation, preventing access to the subset comprisesmaking one or more files in the subset inaccessible at the computingmachine.

Although FIG. 4 shows example blocks of process 400, in someimplementations, process 400 may include additional blocks, fewerblocks, different blocks, or differently arranged blocks than thosedepicted in FIG. 4 . Additionally, or alternatively, two or more of theblocks of process 400 may be performed in parallel.

FIG. 5 is a diagram of an example system 500 in which securing Internetapplications using a dedicated Internet Protocol space may beimplemented, in accordance with some embodiments.

As shown in FIG. 5 , client devices 502, 504, and 506 are connected to anetwork 508 (e.g., the Internet). Each client device 502, 504, and 506may be one of: a laptop computer, a desktop computer, a mobile phone, atablet computer, a digital music player, a personal digital assistant, asmartwatch, and the like. A security service controller 510 is alsoconnected to the network 508. The security service controller 510 may beimplemented as a server, a cluster of servers, or a service coupled witha data repository (e.g., a database). As shown, the client device 502 isassociated with Internet Protocol (IP) address IP-X1. The client device504 is associated with IP address IP-X2. The client device 506 isassociated with IP address IP-X3. The security service controller 510may include one or more servers.

As shown, the security service controller 510 has multiple IP addresses:IP-A1, IP-A2, IP-A3, IP-A4, IP-B1, IP-B2, IP-B3, IP-B4, IP-C1, IP-C2,IP-C3, and IP-C4. Each user-entity (Company A, Company B, and Company C)of the security service controller 510 is assigned a subset of those IPaddresses for its own use. As shown, Company A is assigned IP-A1, IP-A2,IP-A3, and IP-A4. Company B is assigned IP-B1, IP-B2, IP-B3, and IP-B4.Company C is assigned IP-C1, IP-C2, IP-C3, and IP-C4. As used herein, a“user-entity” may be a customer, a client or any other user-entity. Auser-entity of the security service controller 510 may or may not have afinancial relationship with a business providing the security servicecontroller 510. A company may be an organization (e.g., ABC Corporation)or a part of the organization (e.g., the legal team of ABC Corporation).In one example, Company A corresponds to the legal team of ABCCorporation and Company B corresponds to the engineering team of ABCCorporation. As a result, the legal team and the engineering team mayaccess different resources at different IP addresses from one another.

Each user-entity may specify application(s) of the user-entity which maybe accessed via its assigned IP addresses and, in some cases, not viaother server(s). As shown, Company A specifies that its emailapplication (app) and sales app may be accessed via its assigned IPaddresses and, in some cases, not via other server(s). Company Bspecifies that its email app and cloud storage app may be accessed viaits assigned IP addresses and, in some cases, not via other server(s).Company C specifies that its cloud storage app and software as a service(SaaS) app may be accessed via its assigned IP addresses and, in somecases, not via other server(s).

In some embodiments, the security service controller 510 assigns aunique set of IP addresses to each user-entity from among multipleuser-entities. For example, the user-entity Company A is assigned the IPaddresses IP-A1, IP-A2, IP-A3, and IP-A4. The security servicecontroller 510 processes, for a given user-entity, network traffic viathe unique set of IP addresses for the given entity. For example, forCompany A, network traffic is processed via the IP addresses IP-A1,IP-A2, IP-A3, and IP-A4. The security service controller 510 provides,to a client device (e.g., client device 502) authorized by the givenentity, access to network resources (e.g., email app, sales app or otherresources stored or accessed via the network 508) associated with thegiven entity (e.g., Company A) via the unique set of IP addresses(IP-A1, IP-A2, IP-A3, and IP-A4) for the given entity.

In some embodiments, the unique set of IP addresses for the given entitycomprises IP addresses associated with geographic regions. Each IPaddress processes network traffic from the associated geographic region.For example, for Company A, IP-A1 may be associated with thenortheastern United States of America (USA), IP-A2 may be associatedwith the southeastern USA, IP-A3 may be associated with the northwesternUSA, and IP-A4 may be associated with the southwestern USA. If a useraccesses Company A's resources from the northeastern USA, his/hertraffic would be processed via IP-A1. If the user travels to thesoutheastern USA, his/her traffic would be processed via IP-A2 duringhis/her trip.

In some embodiments, the security service controller 510 allows accessto the unique set of IP addresses for the given entity from a predefinedgroup of remote IP addresses specified by the given entity and/orassociated with a user associated with the given entity and not fromother IP addresses outside the predefined group of remote IP addresses.A client device (e.g., client device 502) accessing the data for thegiven entity is associated with an IP address from the predefined group.For example, Company A may specify that IP addresses IP-X1 and IP-X2,but not IP-X3 are allowed to access Company A's data (e.g., the IPaddresses IP-A1, IP-A2, IP-A3, and IP-A4 and the email application andsales application of Company A), thereby allowing client devices 502 and504, but not client device 506, to access Company A's data.

In some embodiments, the security service controller 510 allows accessto a predefined set of applications specified by the given entity fromthe unique set of IP addresses for the given entity and not from otherIP addresses. The client device is running an application from thepredefined set of applications. For example, Company A may specify thatits email app and sales app may be accessed via Company A's assigned IPaddresses: IP-A1, IP-A2, IP-A3, and IP-A4. In this case, the email appand the sales app of Company A would not be accessible from other mailserver(s), application server(s) or web server(s).

In some embodiments, the security service controller 510 determines thatan amount of network traffic associated with the given entity exceeds athreshold. The security service controller 510 assigns one or moreadditional gateways to the unique set of IP addresses for the givenentity. In some embodiments, the network traffic processed for the givenentity is isolated to the unique set of IP addresses for the givenentity. The network traffic may be associated with one or morepredefined applications accessed via the network. A gateway may includea computing machine that transmits data between different networks orapplications. The gateway converts (or forwards without converting) datafrom one protocol or format to another. In some cases, a router mayperform some of the functions of a gateway. In some cases, a gateway mayact as a protocol converter that converts data from one protocol (e.g.,a local network communication protocol) to another protocol (e.g., anInternet communication protocol).

FIG. 6 is a flowchart of an example process 600 associated with securingInternet applications using a dedicated Internet Protocol space. In someimplementations, one or more process blocks of FIG. 6 may be performedby a security service controller (e.g., security service controller 510or computing machine 100). In some implementations, one or more processblocks of FIG. 6 may be performed by another device or a group ofdevices separate from or including the security service controller.Additionally, or alternatively, one or more process blocks of FIG. 6 maybe performed by one or more components of the computing machine 100,such as processor 102, main memory 104, static memory 106, networkinterface device 120, video display 110, alpha-numeric input device 112,UI navigation device 112, drive unit 116, signal generation device 118,and output controller 128.

As shown in FIG. 6 , process 600 may include assigning a unique set ofInternet Protocol (IP) addresses to each entity from among the multipleentities (block 610). For example, the security service controller mayassign a unique set of Internet Protocol (IP) addresses to each entityfrom among the multiple entities, as described above. The securityservice controller may be a security service controller for multipleentities (e.g., Company A, Company B, and Company C, as shown in FIG. 5).

As further shown in FIG. 6 , process 600 may include processing, for agiven entity, network traffic via the unique set of IP addresses for thegiven entity (block 620). For example, the security service controllermay processing, for a given entity, network traffic via the unique setof IP addresses for the given entity, as described above.

As further shown in FIG. 6 , process 600 may include providing, to aclient device authorized by the given entity, access to networkresources associated with the given entity via the unique set of IPaddresses for the given entity (block 630). For example, the securityservice controller may provide, to a client device authorized by thegiven entity, access to network resources associated with the givenentity via the unique set of IP addresses for the given entity, asdescribed above.

Process 600 may include additional implementations, such as any singleimplementation or any combination of implementations described belowand/or in connection with one or more other processes describedelsewhere herein.

In a first implementation, the unique set of IP addresses for the givenentity comprises IP addresses associated with geographic regions, eachIP address processing network traffic from the associated geographicregion.

In a second implementation, process 600 includes allowing access to theunique set of IP addresses for the given entity only from a predefinedgroup of remote IP addresses specified by the given entity and/orassociated with a user associated with the given entity, wherein theclient device is associated with an IP address from the predefinedgroup. Computing machines outside the predefined group of remote IPaddresses may lack access to the unique set of IP addresses or may beblocked (e.g., by the security service controller 510) from accessingthe unique set of IP addresses.

In a third implementation, process 600 includes allowing access to apredefined set of applications specified by the given entity through theunique set of IP addresses for the given entity, wherein the clientdevice is running an application from the predefined set ofapplications.

In a fourth implementation, process 600 includes determining that anamount of network traffic associated with the given entity exceeds athreshold, and assigning, by the security service controller, one ormore additional gateways to the unique set of IP addresses for the givenentity.

In a fifth implementation, the network traffic processed for the givenentity is isolated to the unique set of IP addresses for the givenentity.

Although FIG. 6 shows example blocks of process 600, in someimplementations, process 600 may include additional blocks, fewerblocks, different blocks, or differently arranged blocks than thosedepicted in FIG. 6 . Additionally, or alternatively, two or more of theblocks of process 600 may be performed in parallel.

Some embodiments are described as numbered examples (Example 1, 2, 3,etc.). These are provided as examples only and do not limit thetechnology disclosed herein.

Example 1 is a method comprising: determining, by a security eventdetector, that an active threat exists at a computing machine, whereinthe security event detector resides at the computing machine or in acloud resource, wherein the security event detector identifies activethreats at the computing machine or a network associated with thecomputing machine; preventing, in response to determining that theactive threat exists, access to a subset of computing resourcesaccessible via the computing machine, wherein the subset of computingresources is identified via a security policy that applies to the subsetof computing resources, wherein the security policy does not apply toone or more computing resources stored at the computing machine that arenot in the subset; determining, subsequent to determining that theactive threat exists, that the active threat no longer exists; andallowing, in response to determining that the active threat no longerexists, access to the subset of computing resources.

In Example 2, the subject matter of Example 1 includes, wherein thecomputing machine stores personal computing resources and businesscomputing resources, wherein the subset of computing resources comprisesthe business computing resources and not the personal computingresources, wherein the computing resources comprise files, emailmessages, applications, network ports, network destinations, websiteaccess permissions, and external filesystem access permissions.

In Example 3, the subject matter of Examples 1-2 includes, whereindetermining that the active threat exists comprises: scanning, using thesecurity event detector, the computing machine or the associated networkto identify the active threat.

In Example 4, the subject matter of Examples 1-3 includes, whereindetermining that the active threat no longer exists comprises:persistently checking using the security event detector, once everythreshold time period, whether the active threat still exists at thecomputing machine or the associated network.

In Example 5, the subject matter of Example 4 includes, wherein thethreshold time period is between thirty and ninety seconds.

In Example 6, the subject matter of Examples 1-5 includes, whereinpreventing access to the subset comprises: making a running applicationinaccessible at the computing machine, wherein the running applicationis in the subset or accesses a computing resource from the subset.

In Example 7, the subject matter of Examples 1-6 includes, whereinpreventing access to the subset comprises: making one or more files inthe subset inaccessible at the computing machine.

Example 8 is a method comprising: assigning, by a security servicecontroller for multiple entities, a unique set of Internet Protocol (IP)addresses to each entity from among the multiple entities; processing,for a given entity, network traffic via the unique set of IP addressesfor the given entity; and providing, to a client device authorized bythe given entity, access to network resources associated with the givenentity via the unique set of IP addresses for the given entity.

In Example 9, the subject matter of Example 8 includes, wherein theunique set of IP addresses for the given entity comprises IP addressesassociated with geographic regions, each IP address processing networktraffic from the associated geographic region.

In Example 10, the subject matter of Examples 8-9 includes, allowingaccess to the unique set of IP addresses for the given entity only froma predefined group of remote IP addresses specified by the given entityand/or associated with a user associated with the given entity, whereinthe client device is associated with an IP address from the predefinedgroup.

In Example 11, the subject matter of Examples 8-10 includes, allowingaccess to a predefined set of applications specified by the given entityonly from the unique set of IP addresses for the given entity, whereinthe client device is running an application from the predefined set ofapplications.

In Example 12, the subject matter of Examples 8-11 includes, determiningthat an amount of network traffic associated with the given entityexceeds a threshold; and assigning, by the security service controller,one or more additional gateways to the unique set of IP addresses forthe given entity.

In Example 13, the subject matter of Examples 8-12 includes, wherein thenetwork traffic, associated with one or more predefined applicationsaccessed via the network, processed for the given entity is isolated tothe unique set of IP addresses for the given entity.

Example 14 is at least one machine-readable medium includinginstructions that, when executed by processing circuitry, cause theprocessing circuitry to perform operations to implement of any ofExamples 1-13.

Example 15 is an apparatus comprising means to implement of any ofExamples 1-13.

Example 16 is a system to implement of any of Examples 1-13.

Example 17 is a method to implement of any of Examples 1-13.

Although an embodiment has been described with reference to specificexample embodiments, it will be evident that various modifications andchanges may be made to these embodiments without departing from thebroader spirit and scope of the present disclosure. Accordingly, thespecification and drawings are to be regarded in an illustrative ratherthan a restrictive sense. The accompanying drawings that form a parthereof show, by way of illustration, and not of limitation, specificembodiments in which the subject matter may be practiced. Theembodiments illustrated are described in sufficient detail to enablethose skilled in the art to practice the teachings disclosed herein.Other embodiments may be utilized and derived therefrom, such thatstructural and logical substitutions and changes may be made withoutdeparting from the scope of this disclosure. This Detailed Description,therefore, is not to be taken in a limiting sense, and the scope ofvarious embodiments is defined only by the appended claims, along withthe full range of equivalents to which such claims are entitled.

Although specific embodiments have been illustrated and describedherein, it should be appreciated that any arrangement calculated toachieve the same purpose may be substituted for the specific embodimentsshown. This disclosure is intended to cover any and all adaptations orvariations of various embodiments. Combinations of the aboveembodiments, and other embodiments not specifically described herein,will be apparent to those of skill in the art upon reviewing the abovedescription.

In this document, the terms “a” or “an” are used, as is common in patentdocuments, to include one or more than one, independent of any otherinstances or usages of “at least one” or “one or more.” In thisdocument, the term “or” is used to refer to a nonexclusive or, such that“A or B” includes “A but not B,” “B but not A,” and “A and B,” unlessotherwise indicated. In this document, the terms “including” and “inwhich” are used as the plain-English equivalents of the respective terms“comprising” and “wherein.” Also, in the following claims, the terms“including” and “comprising” are open-ended, that is, a system, userequipment (UE), article, composition, formulation, or process thatincludes elements in addition to those listed after such a term in aclaim are still deemed to fall within the scope of that claim. Moreover,in the following claims, the terms “first,” “second,” and “third,” etc.are used merely as labels, and are not intended to impose numericalrequirements on their objects.

The Abstract of the Disclosure is provided to comply with 37 C.F.R. §1.72(b), requiring an abstract that will allow the reader to quicklyascertain the nature of the technical disclosure. It is submitted withthe understanding that it will not be used to interpret or limit thescope or meaning of the claims. In addition, in the foregoing DetailedDescription, it can be seen that various features are grouped togetherin a single embodiment for the purpose of streamlining the disclosure.This method of disclosure is not to be interpreted as reflecting anintention that the claimed embodiments require more features than areexpressly recited in each claim. Rather, as the following claimsreflect, inventive subject matter lies in less than all features of asingle disclosed embodiment. Thus the following claims are herebyincorporated into the Detailed Description, with each claim standing onits own as a separate embodiment.

What is claimed is:
 1. A method comprising: assigning, by a securityservice controller for multiple entities, a unique set of InternetProtocol (IP) addresses to each entity from among the multiple entities;processing, for a client device authorized by a given entity, networktraffic via the unique set of IP addresses for the given entity; andproviding, to the client device authorized by the given entity, accessto network resources associated with the given entity via the unique setof IP addresses for the given entity.
 2. The method of claim 1, whereinthe unique set of IP addresses for the given entity comprises IPaddresses associated with geographic regions, each IP address processingnetwork traffic from the associated geographic region.
 3. The method ofclaim 1, further comprising: allowing access to the unique set of IPaddresses for the given entity only from a predefined group of remote IPaddresses specified by the given entity and/or associated with a userassociated with the given entity, wherein the client device isassociated with an IP address from the predefined group.
 4. The methodof claim 1, further comprising: allowing access to a predefined set ofapplications specified by the given entity through the unique set of IPaddresses for the given entity, wherein the client device is running anapplication from the predefined set of applications.
 5. The method ofclaim 1, further comprising: determining that an amount of networktraffic associated with the given entity exceeds a threshold; andassigning, by the security service controller, one or more additionalgateways to the unique set of IP addresses for the given entity.
 6. Themethod of claim 1, wherein the network traffic, associated with one ormore predefined applications accessed via the network, processed for thegiven entity is isolated to the unique set of IP addresses for the givenentity.
 7. The method of claim 1, wherein the security servicecontroller is associated with multiple IP addresses and storesapplications and data for multiple entities.
 8. A non-transitorymachine-readable medium storing instructions that, when executed byprocessing circuitry, cause the processing circuitry to performoperations comprising: assigning, by a security service controller formultiple entities, a unique set of Internet Protocol (IP) addresses toeach entity from among the multiple entities; processing, for a clientdevice authorized by a given entity, network traffic via the unique setof IP addresses for the given entity; and providing, to the clientdevice authorized by the given entity, access to network resourcesassociated with the given entity via the unique set of IP addresses forthe given entity.
 9. The machine-readable medium of claim 8, wherein theunique set of IP addresses for the given entity comprises IP addressesassociated with geographic regions, each IP address processing networktraffic from the associated geographic region.
 10. The machine-readablemedium of claim 8, the operations further comprising: allowing access tothe unique set of IP addresses for the given entity only from apredefined group of remote IP addresses specified by the given entityand/or associated with a user associated with the given entity, whereinthe client device is associated with an IP address from the predefinedgroup.
 11. The machine-readable medium of claim 8, the operationsfurther comprising: allowing access to a predefined set of applicationsspecified by the given entity through the unique set of IP addresses forthe given entity, wherein the client device is running an applicationfrom the predefined set of applications.
 12. The machine-readable mediumof claim 8, the operations further comprising: determining that anamount of network traffic associated with the given entity exceeds athreshold; and assigning, by the security service controller, one ormore additional gateways to the unique set of IP addresses for the givenentity.
 13. The machine-readable medium of claim 8, wherein the networktraffic, associated with one or more predefined applications accessedvia the network, processed for the given entity is isolated to theunique set of IP addresses for the given entity.
 14. Themachine-readable medium of claim 8, wherein the security servicecontroller is associated with multiple IP addresses and storesapplications and data for multiple entities.
 15. A system comprising:processing circuitry; and a memory storing instructions that, whenexecuted by processing circuitry, cause the processing circuitry toperform operations comprising: assigning, by a security servicecontroller for multiple entities, a unique set of Internet Protocol (IP)addresses to each entity from among the multiple entities; processing,for a client device authorized by a given entity, network traffic viathe unique set of IP addresses for the given entity; and providing, tothe client device authorized by the given entity, access to networkresources associated with the given entity via the unique set of IPaddresses for the given entity.
 16. The system of claim 15, wherein theunique set of IP addresses for the given entity comprises IP addressesassociated with geographic regions, each IP address processing networktraffic from the associated geographic region.
 17. The system of claim15, the operations further comprising: allowing access to the unique setof IP addresses for the given entity only from a predefined group ofremote IP addresses specified by the given entity and/or associated witha user associated with the given entity, wherein the client device isassociated with an IP address from the predefined group.
 18. The systemof claim 15, the operations further comprising: allowing access to apredefined set of applications specified by the given entity through theunique set of IP addresses for the given entity, wherein the clientdevice is running an application from the predefined set ofapplications.
 19. The system of claim 15, the operations furthercomprising: determining that an amount of network traffic associatedwith the given entity exceeds a threshold; and assigning, by thesecurity service controller, one or more additional gateways to theunique set of IP addresses for the given entity.
 20. The system of claim15, wherein the network traffic, associated with one or more predefinedapplications accessed via the network, processed for the given entity isisolated to the unique set of IP addresses for the given entity.